package com.kangkang.leetcode10;

import java.util.Arrays;

/*
169. 多数元素
简单

给定一个大小为 n 的数组 nums ，返回其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。

你可以假设数组是非空的，并且给定的数组总是存在多数元素。*/
public class Test5 {
    public static void main(String[] args) {
        int[] a = {2,2,1,1,1,2,2};
        System.out.println(Solution5.majorityElement(a));
    }

}
class Solution5 {
    public static int majorityElement(int[] nums) {
        if(nums.length==1)return 1;

        int value  = nums[0];
        int number = 0;
        Arrays.sort(nums);
        int temp = 1;
        for (int i = 1; i < nums.length; i++) {
            if(nums[i] == nums[i-1]){
                temp++;
            }
            if(nums[i] != nums[i-1]||i == nums.length-1){
                if(temp > number){
                    number = temp;
                    value = nums[i-1];
                    temp = 1;
                }
            }
        }
        return value;
    }
}